草庐IT

ios - Xcode 核心数据属性

全部标签

sql - Rails 中独立于数据库的 SQL 字符串连接

我想在Rails查询中进行数据库端字符串连接,并以独立于数据库的方式进行。SQL-92指定双杠(||)作为连接运算符。不幸的是,MSSQLServer似乎不支持它;它使用+代替。我猜Rails的SQL语法抽象已经解决了特定于数据库的运算符问题。如果它确实存在,我该如何使用它? 最佳答案 我遇到了同样的问题,但从未想出任何内置于Rails中的东西。所以我写了这个小方法。#Symbolsshouldbeusedforfieldnames,everythingelsewillbequotedasastringdefdb_concat(*a

ruby-on-rails - 覆盖 rails 中的嵌套属性

当我重写Rails中的嵌套属性方法时会发生什么。例如,classOrderhas_many:line_itemsaccepts_nested_attributes_for:line_itemsdefline_item_attributes=(attr)#whatcanIdohere.endendclassLineItembelongs_to:orderend在上面的代码中,在line_item_attributes=方法中,我可以添加/修改/删除订单的订单项吗?如果我调用@order.save(params),什么时候调用line_items_attributes=?

ruby - 访问 Chef 库中的节点属性

我想创建一个Chef库:提供一些命名空间函数访问节点的属性该库旨在与外部系统交互并从那里检索一些输入。我需要访问节点属性以允许用户覆盖从外部系统接收的输入:所需的用法(配方)inputs=MyLib.get_inputs图书馆(我现在拥有的)这是受thosedocs的启发.classChef::Recipe::MyLibdefself.get_inputsoverride_inputs=node.fetch(:mylib,Hash.new).fetch(:override_inputs,nil)unlessoverride_inputs.nil?returnoverride_input

sql - 将每个 SQL 查询记录到 Rails 中的数据库

我想将某些SQL查询rails执行(即CREATE、UPDATE和DELETE)保存到日志文件中因此我需要拦截所有查询,然后可能使用一些正则表达式过滤它们并根据需要记录它们。我应该把这样的东西放在Rails代码的什么地方? 最佳答案 这里是c0r0ner链接的简化版本,以更好地展示它:connection=ActiveRecord::Base.connectionclasse;end#executeoriginalstatementoriginal_exec(sql,*name)endend

ruby-on-rails - 基于当前的托管服务,我应该将哪些数据库与 Ruby on Rails 一起使用?

我一直在寻找托管服务,但我仍然不知道哪种数据库最常见。好像是MySql和PostgreSql。所以,我不确定我的网站会有多少流量和数据(这只是一个项目),但我想做好准备。我曾在Oracle(PL/SQL)的一些项目中工作过,我对MySql有所了解。谢谢!附言。4年后,我主要使用PostgreSQL编写RoR。当我需要简单的应用程序时默认使用SQLite,否则使用PostgreSQL。 最佳答案 Rails的一个原则是你不应该真正关心你使用的是什么数据库:这些都是为你抽象的。所以我会说选择总体上最好的托管服务提供商,并相信他们会选择一

ruby-on-rails - 如何使用 ActiveRecord 最好地处理每个模型的数据库连接?

我想要规范的方式来做到这一点。我的Google搜索没有结果。我有一个ActiveRecord模型,它应该映射到与应用程序其余部分不同的数据库。我也想将新配置存储在database.yml文件中。我知道应该调用establish_connection,但不清楚在哪里。这是我到目前为止所得到的,但它不起作用:classFoo 最佳答案 此外,将使用不同数据库的模型子类化是个好主意,例如:classAnotherBase在你的模型中classFoo当您需要添加访问同一个数据库的后续模型时,它很有用。

ruby - 如何将数组传递给接受带有 splat 运算符的属性的方法?

如果我有这样的方法:defsum*numbersnumbers.inject{|sum,number|sum+=number}end我怎样才能将数组作为数字传递?ruby-1.9.2-p180:044>sum1,2,3#=>6ruby-1.9.2-p180:045>sum([1,2,3])#=>[1,2,3]请注意,我无法更改sum方法以接受数组。 最佳答案 只是在调用方法的时候放一个splat吗?sum(*[1,2,3]) 关于ruby-如何将数组传递给接受带有splat运算符的属性的

ruby-on-rails - Rails 返回 JSON 序列化属性 with_indifferent_access

我以前有:serialize:params,JSON但这会返回JSON并将哈希键符号转换为字符串。我想使用符号引用散列,这在使用散列时最常见。我给它提供符号,Rails返回字符串。为了避免这种情况,我创建了自己的getter/setter。setter很简单(JSON编码),getter是:defparamsread_attribute(:params)||JSON.parse(read_attribute(:params).to_json).with_indifferent_accessend我不能直接引用params因为那会导致循环,所以我使用read_attribute,现在我的

ruby-on-rails - 动态获取对象的属性

如何动态获取activerecord对象的属性值?例如,我有一个名为attr_name的变量。我想做这样的事情:person=Person.find(1)attr_name="address"address=person.(attr_name)可以使用哪个function_name? 最佳答案 使用person.attributes[attr_name]或person.read_attribute(att_name),或者更短,然后是person[attr_name]. 关于ruby-o

ruby-on-rails - 从数据库中删除一条记录

在RubyonRails中,是@variable.delete还是@variable.destroy 最佳答案 @variable.destroy将调用所有回调(before_destroy等)并确保尊重关联。@variable.delete只是调用原始数据库查询来删除对象。通常,使用destroy会更安全,即使它更昂贵。 关于ruby-on-rails-从数据库中删除一条记录,我们在StackOverflow上找到一个类似的问题: https://stack